/***************************************************************************/
/* Procedimiento:  Trabajo_AlturaInsertar
/* Descripcion:   Insertar o Modifica una fila en la tabla Trabajo_Altura
/* Parametros:    ?InfoParametros
/*                pTransaccion. Numero identificador de la Transaccion
/*                pMensaje. Mensaje de comfirmacion o excepcion
/* Comentarios:         
/****************************************************************************/

PROCEDURE  Trabajo_AlturaInsertarModificar(pnidDocumento NUMBER, pfecha_Inicio VARCHAR2, pfecha_Fin VARCHAR2, 
								pnidArea NUMBER, plocalizacion VARCHAR2, pdescripcion VARCHAR2, 
								pobservaciones VARCHAR2, ppersona VARCHAR2, psuperintendeteObra VARCHAR2, 
								 pTransaccion OUT NUMBER, pMensaje OUT VARCHAR2)
AS
vExisteRegistro NUMBER(1);
BEGIN
  SELECT count(*)
  INTO   vExisteRegistro
  FROM   Trabajo_Altura
  WHERE  nidDocumento=pNidDocumento;
  
  IF vExisteRegistro=0 THEN
    INSERT INTO Trabajo_Altura
	           (nid, nidDocumento, fecha_Inicio, 
				fecha_Fin, nidArea, localizacion, 
				descripcion, observaciones, persona, 
				superintendeteObra)
    VALUES     (seq_Trabajo_Altura.nextval, pnidDocumento, to_date(pfecha_Inicio,'DD/MM/YYYY HH24:MI:SS'), 
				to_date(pfecha_Fin,'DD/MM/YYYY HH24:MI:SS'), pnidArea, plocalizacion, 
				pdescripcion, pobservaciones, ppersona, 
				psuperintendeteObra);
  ELSE
    UPDATE Trabajo_Altura
    SET    nidDocumento=pnidDocumento, fecha_Inicio=to_date(pfecha_Inicio,'DD/MM/YYYY HH24:MI:SS'), 
			fecha_Fin=to_date(pfecha_Fin,'DD/MM/YYYY HH24:MI:SS'), nidArea=pnidArea, localizacion=plocalizacion, 
			descripcion=pdescripcion, observaciones=pobservaciones, persona=ppersona, 
			superintendeteObra=psuperintendeteObra
    WHERE  nidDocumento=pNidDocumento;
  END IF;
  
  COMMIT;
  pTransaccion := 1;
  pMensaje := 'Terminado OK';
  dbms_output.put_line('Terminado OK');

EXCEPTION
  WHEN OTHERS THEN
    pTransaccion := 0;
    pMensaje := 'Error en  Trabajo_Altura_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm;
    dbms_output.put_line('Error en  Trabajo_Altura_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm);
END;
